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> إجابة التمرين الثالث 
#include<iostream.h>‏ 
main()‏ 
{ 
int i,j,n;‏ 
int mat[10][10];‏ 
int product(int mat[ ][10],int n);‏ 


cout<<"Enter value of n\n"; 
cin>>n; 


for(i=0;i<n;ji++) 
for(j=0;j<n;j++) 
cin>>mat[i][j]; 


cout<<"product of main digonal"<< product(mat,n); 


} 
int product(int mat[][10],int n) 
{ 
int i,j,product=1; 
for(i=0;ji<n;ji++) 

for(j=0;j<n;j++) 

f)==j( 
product=product* mat[i] [j]; 


return product; 


} 


4) اكتب برنامجا يبحث عن قيمة × من النوع الصحيح في 
مصفوفة 1|51 ذات البعد الواحد طولها 100 » فإذا كانت 
قيمة × موجودة فاطبع مكان وجودها › واطبع الرسالة 
التالية عند عدم وجودها 

The value of X not found 


#include<iostream.h> 
main() 
{ 
const int MAX =100; 
int i,X,found=0; 
int LIST[MAX]; 


1) المطلوب تعريف مصفوفة من نوع صحيح بها القيم المبدئية الآتية:- 
(20,80,40,10,33,70,55( 


#include<iostream.h> 
main() 
{ 


int i; 
int A[7]={20,80,40,10,33,70,55}; 


for(i=0;i<7;ji++) 
cout<<A[i]; 
} 
المطلوب قراءة مصفوقة ذات بعدين مع إيجاد مجموع قيم العناصر‎ )2 
أعلى القطر الرئيسي من المصفوفة ومجموع عناصر أسفل القطر‎ 
. الرئيسي من المصفوفة‎ 
#include<iostream.h> 
main() 
{ 
int i,j,A[3][3],sum1=0,sum2=0; 


for(i=0;i<3;i++) 
for(j=0;j<3;j++) 
cin>>A[i1[j]; 


for(i=0;i<3;ji++) 
for(j=0;j<3;j++) 


{ 
i۴)i>ز(‎ 
sum1=sum1+A[i][j]; 
else 
if)i<زj)‎ 
sum2=sum2+A[i]1[j]; 
} 
cout<<sum1<<"\n"<<sum2; 
} 


3( المطلوب كتابة برنامج كامل لقراءة مصفوفة ذات بعدين غج بها 
۸× عنصر ثم استخدم دالة لإيجاد حاصل ضرب عناصر القطر 
mat(1,1)*mat(2,2)*...mat(n,n)‏ 
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#include<iostream.h> 
main() 
{ 
int sum1=0,sum2=0; 
int arr[3][2]={ 
{11,2,3,14}, 
{15,6,7,18}, 
{9,3,10,12} 
}; 
for(int i=0;i<3;ji++) 
for(int j=0;j<4jj++) 
if(arr[i][j]%3 !=0) 
sum1+=arr[i][j]; 
else 
sum2+=arr[i][j]; 
cout<<"sum1="<<sUm1<<"sum2="<<sum2<<endl; 
cout<<arr[i][j]xs<sendl; 


} 
SUmM1=44sum2=66 
0 


ناتج البرنامج 


6 اكتب برنامجاً رئيسيا مستدعيا فيه دالة بالشكل التالي :- 
int max(int size,int mat[ ])‏ 
مهمتها إرجاع أكبر عنصر في المصفوفة م والتي طولها 


مأ من العناصر 


#include<iostream.h> 
main() 
{ 
const int n= 100; 
int maximuml(int size,int mat] ]); 


int i,size,result,mat[n]; 
cout<<"Enter number of items\n"; 
cin>>size; 


for(i=0;ji<size;ji++) 
cin>>mat[i]; 


> بقية إجابة التمرين الرابع 
for(i=0;ji<MAX;i++)‏ 
cin>>LIST[i];‏ 


cout<<"Enter wanted number X\n"; 
cin>>X; 


for(i=0;ji<MAX;i++) 
if(LIST[i]==X) 
{ 
found=1; 
cout<<"it's at postion No." <<i; 


} 


if (found==0) 
cout<<"The value of X not found"; 


65 ما هو ناتج تنفيذ البرامج التالية :- 


#include<iostream.h> 
int get_result(int [ ],int); 


main() 


{ 


int cat[8]={4,8,-3,4,1,3,-7,2}; 
cout<<"The result is "<<get_result(cat,8)<<endl; 


return O; 
} 
int get_result(int rat[ ],int length) 
{ 
if(length==1) 
return rat[0]; 
else 
return get_result(rat,length-1)+rat[length-1]; 


he resuاt‎ is 12‏ | ناتچ البرنامج 
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> إجابة التمرين الثامن 
< باستخدام القيم المبدئية 
#include<iostream.h>‏ 
main()‏ 
{ 
int arr[5][5]={‏ 
,}1,0,0,0,0{ 
,}1,1,0,0,0{ 
,}1,1,1,0,0{ 
,}1,1,1,1,0{ 
}1,1,1,1,1{ 
} 
for(int i=0;ji<5;ji++)‏ 
{ 
for(int j=0;j<5;j++)‏ 
cout<<arr[i][j];‏ 
cout<<"\n";‏ 


« باستخدام جمل التكرار 
#include<iostream.h>‏ 
main()‏ 
{ 
int i,j,arr[5][5];‏ 


for(i=0;ji<5;ji++) 
for(j=0;j<5;j++) 
i۴) ز<‎ | | ¡==j( 
arr[il[j]=1; 
else 
arr[il[j]=0; 


for(i=0;i<5;ji++) 
{ 
for( j=0;j<5;j++) 
cout<<arr([i][j]; 
cout<<"\n"; 


} 


> بقية إجابة التمرين السادس 


result = maximum(size,mat); 
cout<<"maximum is "<<result; 


} 


int maximuml(int size,int mat] ]) 


{ 


int i,max=mat[0]; 


for(i=1ji<size;ji++) 
if(mat[i]>max) 
max=mat[i]; 


return max; 


} 


7 في البرنامج بالتمرين (5) فقرة (ط) » ما هي القيمة المخزنة 
بالموقع [۲۲]2[]3ه مع ذكر موقع القيمة 6 في المصفوفة ٣ج‏ 
« القيمة المخزنة بالموقع [2۲۲]2[]3 هي 12 
< موقع القيمة 6 في المصفوفة ۲ج هي [4۲۲]1[]1 
(الصف الثاني والعمود الثاني ) باعتبار أن أول قيمة 
نزن تلقائيا في لغة سي++ عند [۴]0[]0ه إذا ما 
استخدمنا طريقة القيم المبدئية . 
8) المطلوبكتابة برنامج لطباعة المصفوفة ذات البعدين وذلك 
باستخدام القيم المبدئية > مرة وجمل التكرار مرة أخرى »› على 
أن تكون المصفوفة عند طباعتها بالشكل,التالي :- 


کم یم یم یم دم 
کم یم یم یم 
0 © م کم یم 
0 0 0 م ]م 
a CeO ooo‏ 
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0) أكتب برنامجاً كاملا يتم فيه تعريف المصفوفات بالشكل التالي 
int two_array[10][5],one_array[10];‏ 
يتبعها ادخال البيانات الخاصة بالمصفوفة رج٣0_2۲س]‏ ثم 
يقوم البرنامج باستدعاء دالة تحت اسم امع_ اء مهمتها 
ايجاد مجموع كل عمود من أعمدة المصفوفة 0_2۲٣‏ س 
وتخزينها بالمصفوفةا وج٣ة_٥ ٠٣‏ والرجوع بها وطباعتها 
بالبرنامج الرئيسي . 


#include<iostream.h> 
int two_array[10][5],one_array[10]; 


main() 
{ 
int i,j; 
int sum_col(); 


for(i=0;i<10;i++) 
for(j=0;j<5;j++) 
cin>> two_array[i][j]; 


sum_col(); 


for(j=0;j<5;j++) 
cout<<one_arraylj]; 


} 


int sum_col|() 


{ 


int i,j,sum=0; 


for(j=0;j<5;j++) 
{ 
sum=0; 
for(i=0;i<10;i++) 
sum=sum+ two_array[i][j]; 
one_array|[j]=sum; 
} 
return O; 


} 


9) أعطيت مصفوفة ذات بعدين ٣٤م‏ بها 5×5 عنصرا المطلوب 
استخدام دالة واحدة مهمتها الرجوع بالآتي :- 


مجموع عناصر هذه المصفوفة . 
أكبر عنصر في هذه المصفوفة . 
متوسط العناصر الموجبة . 


#include<iostream.h> 
main() 
{ 
int i,j,matr[5][5]; 
float sum=0,sum1=0,a=0,max,avg; 


for(i=0;ji<5;ji++) 
for(j=0;j<5;j++) 
cin>>matr[i] [j]; 


max=matr[0][0]; 
for(i=0;i<5ji++) 
for(j=0;j<5;j++) 
{ 


sum=sum+matr[i][j]; 


if(matr[i] [j]>max) 
max=matr[i][j]; 


if(matr[i][j]>0) 

{ 
sum1=sum1+matr[i] [j]; 
a=a+1; 


1 


avg=sum1/a; 

cout<<"sum of matrix is"<<sum; 
cout<<"max value of matrix is"<<max; 
cout<<"avg of positive values is"<<avg; 
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)11( بقية إجابة تمرين‎ 
void negative() 
{ 
int i,j,b=0; 
for(i=0;ji<5;ji++) 
for(j=0;j<5;j++) 


{ 
if(matr[i][j]<=0) 
{ 
NEGTV[b]=matr[i][j]; 
b=b+1; 
} 
} 


cout<<"negative is\n"; 
for(i=0;i<b;ji++) 
cout<<NEGTV[i]<<"\t"; 
} 


2) أكتب برنامجاً لقراءة مصفوفة عددية ذات بعد واحد تم رتب 
هذه الأعداد ترتييا تصاعدياً » وأيضاً أوجد وسط هذه 
المصفوفة أي العدد الأوسط في حالة أن المصفوفة تحتوي 
على عدد فردي من الأعداد أو متوسط العددين الأوسطين في 
حالة أنها تحتوي على عدد زوجي من العناصر . 


#include<iostream.h> 
main() 
{ 
const int max =100; 
int i,j,temp,m,size,A[max]; 
float avg; 


cout<<"Enter size of matrix"; 
cin>>size; 


for(i=1ji<=sizeji++) 
cin>>A[i]; 


1) نفس البيانات المُعطاة في تمرين (9) مع كتابة دالتين الأولى 
مهمتها تخزين جميع عناصر المصفوفة السالبة في مصفوفة 
أحادية N٤61۷‏ بينما الثانية مهمتها تخزين جميع عناصر 
المصفوفة الموجبة في مصفوفة أحادية ۲051۷ . 

#include<iostream.h> 
int matr[5][5],NEGTV[5*5],POSTV[5*5]; 


main() 
{ 
void positive(); 
void negative(); 
int iyj; 


for(i=0;ji<5;i++) 
for(j=0;j<5;j++) 
cin>>matr([i][j]; 

positive(); 

negative(); 


} 


void positive() 

{ 
int i,j,a=0; 
for(i=0;ji<5;ji++) 
for(j=0;j<5;j++) 


{ 
if(matr[i][j]>=0) 
{ 
POSTV[a]=matr[i] [j]; 
a=a+1; 
} 
} 


cout<<"positiv,is \n"; 
for(i=0;i<aji++) 
cout<<POSTV[i]<<"\t"; 
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إجابة تمرين (13) 
#include<iostream.h>‏ 


main() 

{ 
int i,j,temp,m,A[16]; 
float avg; 


for(i=1;i<=16;i++) 
cin>>A[i]; 


for(i=1;ji<=16-1;ji++) 
for(j=i+1;j<=16;j++) 
{ 
if(Alj] < Al[i]) 
{ 
temp=A[i]; 
A[i]=A[j]; 
Al[j]=temp; 
} 
} 


m=16/2; 


avg=(A[m]+A[m+1])/2.0; 
cout<<avg; 


} 


4) المصفوفتان »×× و إل كل واحدة منها تحتوي على ۸ من 
العناصر ¢ المطلوب دمج المصفوفتين في مصفوفة واحدة 77 
على أن يكون عناصرها في ترتيب تصاعدي » فمتلاً إذا 
كانت 1,3,9=× و 3,6=ل عليه تکون 22=1,3,3,6,9 


#include<iostream.h> 

main() 

{ 
const int max=100; 
int A[max],B[max],C[max]; 
int i,j,temp,n1,n2,n; 


cout<<"Enter size of matrix1"; 
cin>>n1; 


بقية إجابة تمرين (12) 


for(i=1;ji<=size-1;i++) 
for(j=i+1;j<=size;jj++) 
{ 
if(A[j] < A[i]) 
{ 
temp=A[i]; 
Ali]=Ali]; 
Alj]=temp; 
} 
} 


for(i=1ji<=size;ji++) 
cout<<A[i]; 


m=size/2; 


if(size%2!=0) 
cout<<A[m+1]; 


else 

{ 
avg=(A[m]+A[m+1])/2.0; 
cout<<avg; 


} 


3) أعد حل التمرين السابق لايجاد منتصف مصفوفة بها 
عدد زوجي من العناصر وليکن 16 


منتصف المصفوفة (وسط المصفوفة) - مصطلح 
إحصائي- هو العدد الذي ينصف المصفوفة وذلك بعد 
ترتيبها تصاعدياً أو تنازلياً » أما إذا كان عدد عناصر 
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5 أكتب برنامجاً يستقبل مصفوفة صحيحة حجمها 10 مع 
استدعاء دالة مهمتها استقبال هذه المصفوفة والرجوع بقيم 
عناصر هذه المصفوفة غير متكررة في ترتيب تصاعدي › 
فمثلا إذا كانت هذا القيم كالتالي :- 

5 12 9 26 5 77 60 18 209 
تکون العناصر کالوتئ‎ 
5 9 12 18 20 26 60 77 
#include<iostream.h> 
int A[10]; 
main() 
{ int fun(); 
int i; 
for(i=0;i<10;i++) 
cin>>A[i]; 
fun(); 
} 


int fun() 
{ 
int i,j,temp; 
for(i=0;i<10-1;i++) 
for(j=i+1;j<10;j++) 
{ 
if(A[j] < A[i]) 
{ 
temp=A[i]; 
A[i]=Alj]; 
Alij]=temp; 


} 


for(i=0;i<10;i++) 
{ 
if(A[i]==A[i+1]) 
continue; 
cout<<A[i]; 
} 
return O; 


} 


> بقية إجابة تمرين رقم (14) 


cout<<"Enter size of matrix2"; 
cin>>n2; 


for(i=0;ji<n1;ji++) 
cin>>A[i]; 


for(i=0;i<n1;i++) 
C[i]=A[i]; 


cout<<"Enter items of matrix B\n"; 
for(i=n1ji<n;ji++) 
cin>>B[i]; 


for(i=n1;ji<n;ji++) 
C[i]=B[i]; 


n=n1+n2; 


for(i=0;i<n-1;ji++) 
for(j=i+1;j<n;j++) 
{ 
if(CL] < C[i]) 
{ 
temp=C[i]; 
C[i]=CÛj]; 
C[j]=temp; 
} 
} 


for(i=0;ji<n;ji++) 
cout<<C[i]; 


} 
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